package com.yix.admin.modules.system.repository;

import com.yix.admin.modules.system.entity.SysMenu;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;

import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;

/**
 * @author wdx
 * @version 1.0
 * @Description TODO
 * @date 2021/1/27 16:47
 */
@SuppressWarnings("all")
public interface SysMenuRepository extends JpaRepository<SysMenu, String>, JpaSpecificationExecutor<SysMenu> {

    /**
     * 根据角色ID与菜单类型查询菜单
     * @param roleIds roleIDs
     * @param type 类型
     * @return /
     */
    @Query(value = "SELECT m.* FROM sys_menu m, roles_menus r WHERE " +
            "m.id = r.menu_id AND r.role_id IN ?1 AND type != ?2 order by m.menu_sort asc",nativeQuery = true)
    LinkedHashSet<SysMenu> findByRoleIdsAndTypeNot(Set<String> roleIds, int type);

    /**
     * 查询顶级菜单
     * @return /
     */
    List<SysMenu> findByPidIsNull();

    /**
     * 根据菜单的 PID 查询
     * @param pid /
     * @return /
     */
    List<SysMenu> findByPid(String pid);

    /**
     * 根据菜单标题查询
     * @param title 菜单标题
     * @return /
     */
    SysMenu findByName(String name);

    /**
     * 根据组件名称查询
     * @param name 组件名称
     * @return /
     */
    SysMenu findByComponentName(String name);

    /**
     * 获取节点数量
     * @param id /
     * @return /
     */
    int countByPid(String id);

    /**
     * 更新节点数目
     * @param count /
     * @param menuId /
     */
    @Modifying
    @Query(value = " update sys_menu set sub_count = ?1 where id = ?2 ",nativeQuery = true)
    void updateSubCntById(int count, String menuId);



}
